# Circuitos Combinacionais



# **Circuitos combinacionais**

Um circuito combinacional é um circuito em que o valor das saídas em qualquer instante de tempo, depende unicamente dos valores lógicos presentes nas entradas, nesse instante.

Um circuito deste tipo executa uma função lógica **F**, através da interligação de várias **portas lógicas**.



Modelo genérico de um circuito combinacional



# Circuitos combinacionais dedicados

Existem diversos circuitos combinacionais que são frequentemente utilizados em projectos de sistemas digitais, devido às funções lógicas que implementam.

Estes circuitos encontram-se comercialmente disponíveis sob a forma de circuitos integrados e, por isso, designam-se por circuitos combinacionais dedicados.

Exemplos destes circuitos:

Codificadores (Encoders), Descodificadores (Decoders), Multiplexadores (Multiplexers), Desmultiplexadores (Demultiplexers), Comparadores (Comparators), Somadores (Binary Adders), ...



# Multiplexadores (MUX)

Os Multiplexadores ou MUX são circuitos que, possuindo várias entradas e uma só saída, permitem seleccionar uma dessas entradas reproduzindo-a na saída. Essa selecção é feita através de um código binário que é aplicado às entradas (ou linhas) de selecção.

Estes circuitos são utilizados para diversas finalidades, como sejam: selecção de dados, conversão paralelo-série, implementação de funções lógicas, ... Exemplo de um **MUX** com **4** entradas de dados, ou **MUX 4:1**:







# Implementação de um MUX 4:1:



$$Y = (\bar{B} \cdot \bar{A}) \cdot D_0 + (\bar{B} \cdot A) \cdot D_1 + (B \cdot \bar{A}) \cdot D_2 + (B \cdot A) \cdot D_3$$

Apresentam-se em seguida, alguns exemplos de Multiplexadores disponíveis no mercado sob a forma de circuitos integrados da família TTL.

A informação relativa aos diversos circuitos integrados, foi retirada das respectivas data sheets (www.datasheetcatalog.com).

\_\_\_\_\_\_

Circuito comercial **74157** (4 MUX 2:1):

#### **Connection Diagram**



#### **Function Table**

|        | Inputs |   |   | Output Y |
|--------|--------|---|---|----------|
| Strobe | Select | Α | В | Output   |
| Н      | Х      | X | X | L        |
| L      | L      | L | X | L        |
| L      | L      | Н | X | Н        |
| L      | н      | X | L | L        |
| L      | Н      | X | Н | Н        |

H = High Level, L = Low Level, X = Don't Care



#### Relativamente ao circuito anterior, verifica-se o seguinte:

- Strobe = H → "desactiva" o circuito
- **Strobe** = **L** → "deixa o circuito funcionar"
- As letras X presentes nas entradas da tabela de verdade, significam:
   "qualquer que seja o valor lógico da entrada..."
- Select selecciona uma das entradas A ou B → esta selecção é comum aos 4 Multiplexadores
- A saída Y reproduz a entrada seleccionada





# Circuito comercial **74153** (2 MUX 4:1):

#### **Connection Diagram**





#### **Function Table**

| Sel |   |   | Data I | nputs |     | Strobe | Output |
|-----|---|---|--------|-------|-----|--------|--------|
| В   | A | ĉ | ū      | C2    | င္ပ | G      | Υ      |
| Х   | Х | Х | Х      | X     | X   | I      | Г      |
| L   | L | L | Χ      | Χ     | Χ   | L      | L      |
| L   | L | Н | Χ      | Χ     | Χ   | L      | Н      |
| L   | Н | X | L      | X     | Х   | L      | L      |
| L   | Н | Х | Н      | Х     | Χ   | L      | Н      |
| Н   | L | Χ | Χ      | L     | Χ   | L      | L      |
| Н   | L | Х | Х      | Н     | Χ   | L      | Н      |
| Н   | Н | Χ | Χ      | Χ     | L   | L      | L      |
| Н   | Н | Х | Χ      | Χ     | Н   | L      | Н      |

Select inputs A and B are common to both sections.

H = High Level, L = Low Level, X = Don't Care



Circuito comercial **74151** (1 MUX 8:1):

#### Connection Diagram

#### **Function Table**

#### **Dual-In-Line Package**



54151A/75151A

|   | I      | nputs |        | Out | puts |
|---|--------|-------|--------|-----|------|
|   | Select |       | Strobe | v   | w    |
| С | В      | A     | s      | •   | ••   |
| х | Х      | Х     | Н      | L   | Н    |
| L | L      | L     | L      | D0  | D0   |
| L | L      | Н     | L      | D1  | D1   |
| L | Н      | L     | L      | D2  | D2   |
| L | Н      | Н     | L      | D3  | D3   |
| Н | L      | L     | L      | D4  | D4   |
| Н | L      | Н     | L      | D5  | D5   |
| Н | Н      | L     | L      | D6  | D6   |
| Н | Н      | Н     | L      | D7  | D7   |

H = High Level, L = Low Level, X = Don't Care

Note-se que as saídas Y e W são complementares uma da outra.



Circuito comercial **74150** (1 MUX 16:1):

#### **Connection Diagram**



#### **Function Table**

54150/74150

|   |     | Inpu | ıts |        |              |
|---|-----|------|-----|--------|--------------|
|   | Sel | ect  |     | Strobe | Outputs<br>W |
| D | С   | В    | Α   | s      |              |
| X | Х   | Х    | Х   | Η      | Н            |
| L | L   | L    | L   | L      | E0           |
| L | L   | L    | Н   | L      | E1           |
| L | L   | Н    | L   | L      | E2           |
| L | L   | н    | Н   | L      | E3           |
| L | н   | L    | L   | L      | E4           |
| L | н   | L    | Н   | L      | E5           |
| L | н   | Н    | L   | L      | E6           |
| L | н   | Н    | Н   | L      | E7           |
| Н | L   | L    | L   | L      | E8           |
| Н | L   | L    | Н   | L      | E9           |
| Н | L   | н    | L   | L      | E10          |
| Н | L   | н    | н   | L      | E11          |
| Н | н   | L    | L   | L      | E12          |
| Н | н   | L    | Н   | L      | E13          |
| Н | н   | н    | L   | L      | E14          |
| Н | Н   | Н    | Н   | L      | E15          |

H = High Level, L = Low Level, X = Don't Care

E0, E1 ... E15 = the complement of the level of the respective E input



# **Expansão de Multiplexers**

Para se multiplexarem mais sinais do que aqueles que um MUX permite, associam-se vários MUX.

Por exemplo, para se obter um MUX de 32 entradas, podem associar-se dois MUX de 16 entradas cada.

- O sinal Strobe comporta-se como "mais uma linha de selecção", S4
- Como no 74150 a saída W é negada e é H quando circuito inactivo, há que invertê-la (⇒ L) e há que fazer um OR das saídas





# **Expansão de Multiplexers**

A figura apresenta um MUX de 8 entradas construído a partir de dois multiplexadores de 4 entradas e um outro multiplexador de duas entradas, considerando que a entrada A é a mais significativa.





# Expansão de Multiplexers com descodificador

Outro método alternativo utiliza um descodificador para seleccionar um dos multiplexers.





# Implementação de funções lógicas com Multiplexers

Como foi inicialmente referido, os MUX podem ser usados para **implementar funções lógicas**.

Por exemplo, a seguinte **função F de 3 variáveis** pode ser implementada com, unicamente, um **MUX 8:1**:



Com efeito, verifica-se que qualquer função de **n** variáveis pode ser implementada usando apenas um **MUX** de **2**<sup>n</sup>:1.

Mas, para além disso, um **MUX** também permite implementar uma função lógica com redução de **uma ou mais variáveis**.

#### **Exemplo**

Imagine que se pretende implementar a função F de 4 variáveis, dada pela tabela ao lado, com base num MUX 8:1.



Circuitos Combinacionais



# **Descodificadores (DEC)**

Os **Descodificadores**, ou **DEC**, são circuitos que recebem um conjunto de entradas que representam um dado número binário, e activam apenas a saída que corresponde a esse número (todas as outras saídas permanecem inactivas).

\*\*n entradas\*\*



Se um descodificador possuir **n** entradas, há **2**<sup>n</sup> possibilidades de combinações, ou códigos, de entrada. No entanto, existem descodificadores que não utilizam todas as **2**<sup>n</sup> possibilidades, mas apenas algumas delas.



# Algumas aplicações dos Descodificadores



Uma das maiores aplicações dos **Descodificadores** consiste no accionamento de *displays*: interpretando o código binário presente nas entradas (representante de letras ou números) e gerando os sinais adequados para ligar o dígito correspondente a esse código.

Por outro lado, se as entradas de um **Descodificador** forem geradas por um circuito sequencial designado por **Contador** que gera uma sequência de códigos binários (a estudar mais à frente), as suas saídas podem ser usadas como sinais de temporização ou de sequenciamento, para ligar/desligar determinados dispositivos em dados momentos.



Exemplo de um **Descodificador** ou **DEC 3:8** (3 linhas de entrada e 8 linhas de saída):

Entradas



| С | В | A | YO | Y1 | Y2 | YЗ | Y4 | Y5 | Y6 | Y7 |   |
|---|---|---|----|----|----|----|----|----|----|----|---|
| 0 | 0 | 0 | B  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |   |
| ٥ | 0 | 1 | 1  | D  | 1  | 1  | 1  | 1  | 1  | 1  |   |
| 0 | 1 | 0 | 1  | 1  | D  | 1  | 1  | 1  | 1  | 1  | _ |
| Đ | 1 | 1 | 1  | 1  | 1  | D  | ست | -  | 1  | 1  |   |
| 1 | 0 | 0 | 1  | 1  | 1  | 1  | 0  | 1  | 1  | 1  |   |
| 1 | 0 | 1 | 1  | 1  | 1  | 1  | 1  | O  | 1  | 1  |   |
| 1 | 1 | 0 | 1  | 1  | 1  | 1  | 1  | 1  | 0  | 1  |   |
| 1 | 1 | ī | 1  | 1  | 1  | 1  | i  | 1  | 1  | D  |   |

Note-se que as saídas são **active-low** (ou seja, activas ao **nível baixo**)



# **Desmultiplexadores (DEMUX)**

Um **Desmultiplexador**, ou **DEMUX**, é um circuito que realiza a operação inversa de um **Multiplexador**. Possuindo uma única entrada e várias saídas, transfere o valor da entrada para a saída seleccionada pelo código binário presente nas linhas de selecção.

# Algumas aplicações dos Desmultiplexadores

Um **DEMUX** pode, por exemplo, ser usado como Desmultiplexador de *Clock* (relógio), direccionando este sinal para o destino determinado pelas linhas de selecção.

Pode igualmente ser usado como parte de um sistema síncrono de transmissão de dados em série, entre um emissor e um receptor remoto (existirá um **MUX** no lado emissor e um **DEMUX** no lado receptor).

#### Sistemas Digitais 2023/2024

Exemplo de um **Desmultiplexador** de 1 entrada e 8 saídas, ou **DEMUX 1:8**:



| <u>c</u> | В | A | YO | Y1 | Y2 | Y3 | <b>Y</b> 4 | Y5 | Y6 | <b>Y7</b> |
|----------|---|---|----|----|----|----|------------|----|----|-----------|
| 0        | Ö | 0 | E  | 1  | 7  | 1  | 1          | 1  | 1  | 1         |
| 0        | 0 | 1 | 1  | E  | 7  | 1  | 1          | 1  | 1  | 1         |
| 0        | 7 | 0 | 1  | 7  | E  | 1  | 1          | 7  | 1  | 1         |
| Đ        | 1 | 1 | 1  | 1  | 1  | E  | 1          | 3  | 1  | 1         |
| 1        | 0 | 0 | 1  | 1  | វ  | 1  | E          | 1  | 1  | 1         |
| 1        | 0 | 1 | 1  | 1  | 1  | 1  | 1          | E  | 1  | 1         |
| 1        | 1 | 0 | 7  | 7  | 7  | 1  | 1          | 1  | E  | 1         |
| 7        | 1 | 1 | 1  | 1  | 1  | 1  | i          | 1  | 1  | E         |

Note-se que **E** é a informação presente na entrada de dados

Pela observação das tabelas de verdade relativas ao **Descodificador** e ao **Desmultiplexador**, pode concluir-se que é simples combiná-los a ambos num único dispositivo.

Com efeito, esta solução é adoptada pelos circuitos comercialmente disponíveis, os quais podem ser usados quer como Desmultiplexadores, quer como Descodificadores. É por este motivo que são designados por *Descodificadores/Desmultiplexadores.* 

Apresentam-se em seguida alguns exemplos destes circuitos, disponíveis no mercado sob a forma de CIs da família TTL.

Circuito comercial 74138 (um DEC/DEMUX 3:8):

#### **Connection Diagram**

# DM74LS138 DATA OUTPUTS VCC Y0 Y1 Y2 Y3 Y4 Y5 Y6 16 15 14 13 12 11 10 9 1 2 3 4 5 6 7 8 A B C G2A G2B G1 Y7 GND SELECT ENABLE

#### **Function Table**

DM74LS138

|    | Inputs      |   |     |    |    |    | _  | Outr | outs |    |    | $\Box$ |
|----|-------------|---|-----|----|----|----|----|------|------|----|----|--------|
|    | Enable      | S | ele | ct |    |    | `  | ouq  | Juio |    |    |        |
| G1 | G2 (Note 1) | С | В   | Α  | YO | Y1 | Y2 | Y3   | Y4   | Y5 | Y6 | Y7     |
| Х  | Н           | Х | Χ   | Χ  | Н  | Н  | Н  | Н    | Н    | Н  | Η  | Н      |
| L  | Х           | Х | Х   | Х  | Н  | Н  | Н  | Н    | Н    | Н  | Н  | Н      |
| Н  | L           | L | L   | L  | 1  | Н  | Н  | Н    | Н    | Н  | Н  | Н      |
| Н  | L           | L | L   | Н  | Н  | L  | Н  | Н    | Н    | Н  | Н  | Н      |
| Н  | L           | L | Н   | L  | Н  | Н  | 7  | Н    | Н    | Н  | Н  | Н      |
| Н  | L           | L | Н   | Н  | Н  | Н  | Н  | 7    | Н    | Н  | Н  | Н      |
| Н  | L           | Н | L   | L  | Н  | Н  | Н  | Н    | 1    | Н  | Н  | Н      |
| Н  | L           | Н | L   | Н  | Н  | Н  | Н  | Н    | Н    | Y  | Н  | Н      |
| Н  | L           | Н | Н   | L  | Н  | Н  | Н  | Н    | Н    | Н  | ¥  | Н      |
| Н  | L           | Н | Н   | Н  | Н  | Н  | Н  | Н    | Н    | Н  | Н  | 4      |

Note 1: G2 = G2A + G2B



#### **Notas:**

- Este circuito tem três entradas de *Enable*: duas activas ao nível L e uma activa ao nível H.
- Estas entradas evitam a necessidade de lógica externa em caso de expansão.
- Uma destas entradas pode ser usada como entrada de dados em situações de "desmultiplexação".



Circuito comercial 74154 (um DEC/DEMUX 4:16):

# **Connection Diagram**

#### Dual-In-Line Package





#### **Function Table**

|    |    | Inpu | ts |   |   |   |   |   |   |   |   |   | 0 | utpu | ts |    |    |    |    |    |    |
|----|----|------|----|---|---|---|---|---|---|---|---|---|---|------|----|----|----|----|----|----|----|
| G1 | G2 | D    | С  | В | Α | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8    | 9  | 10 | 11 | 12 | 13 | 14 | 15 |
| L  | L  | L    | L  | L | L | L | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | L    | L  | L | Н | Н | Ł | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | L    | L  | Н | L | Н | Н | L | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | L    | L  | Н | Н | Н | Н | Н | L | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | L    | Н  | L | L | Н | Н | Н | Н | L | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | L    | Н  | L | Н | Н | Н | Н | Н | Н | L | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | L    | Н  | Н | L | Н | Н | Н | Н | Н | Н | L | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | L    | Н  | Н | Н | Н | Н | Н | Н | Н | Н | Н | L | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | н    | L  | L | L | Н | Н | Н | Н | Н | Н | Н | Н | L    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | Н    | L  | L | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н    | L  | Н  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | н    | L  | Н | L | Н | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | L  | Н  | Н  | Н  | Н  | Н  |
| L  | L  | н    | L  | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | L  | Н  | Н  | Н  | Н  |
| L  | L  | Н    | Н  | L | L | Н | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | L  | Н  | Н  | Н  |
| L  | L  | н    | Н  | L | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | 1  | Н  | Н  |
| L  | L  | Н    | Н  | Н | L | Н | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | 1  | Н  |
| L  | L  | Н    | Н  | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | 1  |
| L  | Н  | Х    | Х  | Х | Х | Н | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| Н  | L  | Х    | Х  | Х | Х | Н | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |
| Н  | Н  | Х    | X  | Х | Х | Н | Н | Н | Н | Н | Н | Н | Н | Н    | Н  | Н  | Н  | Н  | Н  | Н  | Н  |

H = High Level, L = Low Level, X = Don't Care



Circuito comercial 7442 (um DEC/DEMUX 4:10):

Este é um descodificador de BCD para decimal:

- Tem apenas 10 combinações de entrada válidas (as outras 6 são inválidas)
- Utiliza-se para "fazer corresponder" aos códigos binários de 0000 a 1001, dez saídas representativas dos dez dígitos decimais 0...9

#### Connection Diagram



#### **Function Table**

| No. |   | BCD | Input |   |   |   |   | D | ecima | Outp | ut |   |   |     |
|-----|---|-----|-------|---|---|---|---|---|-------|------|----|---|---|-----|
|     | D | С   | В     | Α | 0 | 1 | 2 | 3 | 4     | 5    | 6  | 7 | 8 | 9   |
| 0   | L | L   | L     | L | L | Н | Н | Н | Н     | Н    | Н  | Н | Н | Н   |
| 1   | L | L   | L     | Н | Н | L | Н | Н | Н     | Н    | Н  | Н | Н | Н   |
| 2   | L | L   | Н     | L | Н | Н | L | Н | Н     | Н    | Н  | Н | Н | Н   |
| 3   | L | L   | Н     | Н | Н | Н | Н | L | Н     | Н    | Н  | Н | Н | Н   |
| 4   | L | Н   | L     | L | Н | Н | Н | Н | L     | Н    | Н  | Н | Н | н   |
| 5   | L | Н   | L     | Н | Н | Н | Н | Н | Н     | L    | Н  | Н | Н | Н   |
| 6   | L | Н   | Н     | L | Н | Н | Н | Н | Н     | Н    | L  | Н | Н | Н   |
| 7   | L | Н   | Н     | Н | н | Н | Н | Н | Н     | Н    | Н  | L | Н | Н   |
| 8   | н | L   | L     | L | н | Н | Н | Н | Н     | Н    | Н  | Н | L | Н   |
| 9   | Н | L   | L     | Н | Н | Н | Н | Н | Н     | Н    | Н  | Н | Н | L   |
| +   | Н | L   | Н     | L | Н | Н | Н | Н | Н     | Н    | Н  | Н | Н | _#_ |
| N   | Н | L   | Н     | Н | Н | Н | Н | Н | Н     | Н    | Н  |   | Н | Н   |
| V   | н | Н   | L     | L | Н | Н | Н | Н | Н     | -    | Н  | Н | Н | Н   |
| Α   | н | Н   | L     | Н | Н | Н | ) | Ħ | Н     | Н    | Н  | Н | Н | Н   |
| L   | н | Н   | Н     | L | Щ | Н | Н | Н | #     | Н    | Н  | Н | Н | Н   |
| - 1 | н | Н   |       | Н | Н | Н | Н | Н | Н     | Н    | #  | Н | Н | н   |
| D   |   |     |       |   |   |   |   |   |       |      |    |   |   |     |

H = HIGH Level L = LOW Level



# Expansão de descodificadores

Para se obterem circuitos descodificadores com mais saídas do que aquelas que um só DEC permite, associam-se vários DEC.

Veja-se, por exemplo, como é possível obter um **DEC 8:256**, à custa de 1+16=**17 DEC 4:16**.





# Implementação de funções lógicas com descodificadores

Tal como os **Multiplexadores**, também os **Descodificadores** podem ser usados para a implementação de Funções Lógicas.

Com efeito, verifica-se que cada saída de um **Descodificador** corresponde a um termo da função de **n** variáveis que ele descodifica.

Por este motivo, para implementar uma função à custa de um Descodificador, basta fazer o **OR** dos termos que compõem a função a implementar.

Consegue-se assim implementar a função a partir da Forma Canónica Soma de Produtos.



#### **Exemplo**



Como no 74154 as saídas são o complemento dos termos, em vez do **OR** usa-se um **NAND** (que é um OR com as entradas negadas). Ligam-se ao NAND os termos que dão valor **1** à função F.



# **Comparadores**

Os **Comparadores** permitem determinar se dois números binários são iguais e, se não forem, indicam qual deles é maior.

Circuito comercial 7485 (compara dois números binários de 4 bits)



- A3, B3 = *Most Significant bit* (MSb)
- A0, B0 = Less Significant bit (LSb)





#### Algoritmo utilizado para a comparação:

Se A3>B3 então A>B

Senão

Senão Se A3<B3 então A<B

Senão

Se A2>B2 então A>B Senão Se A2<B2 então A<B

---

| E       | ntradas de | сотрага | ção     |     | Saídas |       |
|---------|------------|---------|---------|-----|--------|-------|
| A3,83   | A2,B2      | A1,91   | AO,BO   | A>B | A < B  | A = B |
| A3 > B3 | Х          | Х       | Х       | 1   | 0      | 0     |
| A3 < B3 | ×          | Х       | x       | b   | Ä      | ٥     |
| A3 ≈ B3 | A2 > B2    | x       | x       | 1   | 0      | Û     |
| A3 = B3 | A2 < B2    | ×       | х       | 0   | 1      | o     |
| A3 = B3 | A2 = B2    | A1 > B1 | х .     | 1   | O      | 0     |
| A3 ≖ B3 | A2 = B2    | A1 < B1 | x       | 0   | 1      | 0     |
| A3 = B3 | A2 = B2    | A1 = B1 | A0 > B0 | 1   | 0      | 0     |
| A3 = B3 | A2 = B2    | A1 = B1 | A0 < B0 | 0   | 1      | 0     |
| A3 = B3 | A2 = B2    | A1 = B1 | A0 = B0 | 0   | 0      | 1     |

Senão A=B

#### Sistemas Digitais 2023/2024

Como um "algoritmo" deste tipo pode ser estendido a **N** *bits*, os comparadores comerciais incluem 3 entradas que permitem ligá-los a um comparador "anterior", em **cascata** (*cascading inputs*).

Podem assim comparar-se **palavras** de **Nx4** *bits* (**palavra** = grupo de *bits* que representa um determinado tipo de informação).





# Comparação de palavras de **N**x4 *bits*:

| A0 7485                                                                                                                                         |     | ntradas<br>expansā                                                                                                                        |     | E              | ntradas de | comparação | 0       | s   | aidas                         |     |
|-------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------|------------|------------|---------|-----|-------------------------------|-----|
| A1<br>A2<br>A3<br>A3                                                                                                                            | A>B | A <b< td=""><td>A≖B</td><td>A3,B3</td><td>A2,B2</td><td>A1,B1</td><td>A0,B0</td><td>A&gt;B</td><td>A<b< td=""><td>A≘B</td></b<></td></b<> | A≖B | A3,B3          | A2,B2      | A1,B1      | A0,B0   | A>B | A <b< td=""><td>A≘B</td></b<> | A≘B |
| A-B                                                                                                                                             | Х   | Х                                                                                                                                         | Х   | A3 > B3        | ×          | Х          | Х       | 1   | 0                             | 0   |
| B0<br>                                                                                                                                          | х   | х                                                                                                                                         | X   | A3 < B3        | ×          | х          | ×       | ٥   | 1                             | 0   |
| B2 A <b< td=""><td>Х</td><td>Х</td><td>X</td><td>A3 <b>-</b> B3</td><td>A2 &gt; B2</td><td>х</td><td>х</td><td>1</td><td>C</td><td>٥</td></b<>  | Х   | Х                                                                                                                                         | X   | A3 <b>-</b> B3 | A2 > B2    | х          | х       | 1   | C                             | ٥   |
| A>В <sub>іп</sub>                                                                                                                               | Х   | Х                                                                                                                                         | ,X  | A3 = B3        | A2 < B2    | Х          | Χ.      | 0   | 1                             | ٥   |
| A=8 in                                                                                                                                          | х   | х                                                                                                                                         | Х   | A3 = B3        | A2 = B2    | A1 > B1    | X       | 1   | 0                             | 0   |
| A <b in<="" td=""><td>х</td><td>х</td><td>Х</td><td>A3 = B3</td><td>A2 = B2</td><td>A1 &lt; B1</td><td>×</td><td>0</td><td>1</td><td>0</td></b> | х   | х                                                                                                                                         | Х   | A3 = B3        | A2 = B2    | A1 < B1    | ×       | 0   | 1                             | 0   |
|                                                                                                                                                 | Х   | х                                                                                                                                         | Х   | A3 = B3        | A2 = B2    | A1 = B1    | A0 > B0 | 1   | 0                             | ٥   |
| Se do comparador                                                                                                                                | Х   | X.                                                                                                                                        | X   | A3 = B3        | A2 = B2    | A1 = B1    | A0 < B0 | 0   | 1                             | 0   |
|                                                                                                                                                 | 1   | Ó                                                                                                                                         | Û   | A3 = B3        | A2 = B2    | A1 = B1    | A0 = B0 | 1   | Q.                            | 0   |
| anterior vem <b>A&gt;B</b>                                                                                                                      | 0   | 1                                                                                                                                         | 0   | A3 = B3        | A2 = B2    | A1 = B1    | A0 = B0 | Ō   | 1                             | 0   |
|                                                                                                                                                 | Х   | Х                                                                                                                                         | 1   | A3 = B3        | A2 = B2    | A1 = B1    | A0 = B0 | 0   | 0                             | 1   |
| e no actual <b>A=B</b>                                                                                                                          | 1   | 1                                                                                                                                         | 0   | A3 = B3        | #2 = B2    | A1 = B1    | A0 = B0 | 0   | 0                             | 0   |
| (a2 b2 a0 b0)                                                                                                                                   | - 0 | 0                                                                                                                                         | 0   | A3 - B3        | A2 = B2    | A1 = B1    | A0 = B0 | 1   | 1 .                           | 0   |
| (a3=b3a0=b0), ———                                                                                                                               |     |                                                                                                                                           |     |                |            |            |         |     |                               |     |
| então o resultado                                                                                                                               |     |                                                                                                                                           |     |                |            |            |         |     |                               |     |
| final é ainda <b>A&gt;B</b>                                                                                                                     |     |                                                                                                                                           |     |                |            |            |         |     |                               |     |



Veja-se o seguinte exemplo, em que um **Comparador** de **12** *bits* é implementado à custa de três **Comparadores** de **4** *bits*:

No primeiro comparador (*bits* menos significativos) ligam-se as entradas ">", "=" e "<", a 0, 1 e 0, respectivamente, para activar a saída "A=B", no caso de x3=y3, x2=y2, x1=y1 e x0=y0.

|     | ntradas<br>xpansā                                                                                                                           |     | E       | ntradas de i | comparação | ,       | s   | aidas                         |     |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------|-----|---------|--------------|------------|---------|-----|-------------------------------|-----|
| A>B | A <b< th=""><th>A≖B</th><th>A3,B3 ·</th><th>A2,B2</th><th>A1,B1</th><th>A0,B0</th><th>A&gt;B</th><th>A<b< th=""><th>A≘B</th></b<></th></b<> | A≖B | A3,B3 · | A2,B2        | A1,B1      | A0,B0   | A>B | A <b< th=""><th>A≘B</th></b<> | A≘B |
| Х   | х                                                                                                                                           | ×   | A3 > B3 | ×            | X          | Х       | 1   | 0                             | 0   |
| x   | х                                                                                                                                           | х   | A3 < B3 | x            | х          | x       | a   | 1                             | 0   |
| ×   | х                                                                                                                                           | X   | A3 - B3 | A2 > B2      | х          | х       | 1   | G                             | ٥   |
| ×   | Х                                                                                                                                           | X   | A3 = B3 | A2 < B2      | х          | Χ.      | 0   | 1                             | ٥   |
| ×   | х                                                                                                                                           | X · | A3 = B3 | A2 = B2      | A1 > B1    | X       | 1   | 0                             | 0   |
| ×   | х                                                                                                                                           | Х   | A3 = B3 | A2 = B2      | A1 < B1    | x       | 0   | 1                             | 0   |
| x   | х                                                                                                                                           | Х   | A3 = B3 | A2 = B2      | A1 = B1    | A0 > B0 | 1   | 0                             | ٥   |
| ×   | х                                                                                                                                           | x   | A3 = B3 | A2 = B2      | A1 = B1    | A0 < B0 | 0   | 1                             | 0   |
| 1   | 0                                                                                                                                           | 0   | A3 = B3 | A2 = B2      | A1 = B1    | A0 = B0 | 1   | 0                             | 0   |
| 0   | 1                                                                                                                                           | 0   | A3 = B3 | A2 = B2      | A1 = B1    | A0 = B0 | ٥   | 1                             | 0   |
| Х   | х                                                                                                                                           | 1   | A3 = B3 | A2 = B2      | A1 = B1    | A0 = B0 | 0   | 0                             | 1   |
| 1   | 1                                                                                                                                           | 0   | A3 = B3 | A2 ≃ B2      | A1 = B1    | A0 = B0 | 0   | 0                             | 0   |
| - o | 0                                                                                                                                           | 0   | A3 = B3 | A2 = B2      | A1 = B1    | A0 ≈ B0 | 1   | 1                             | 0   |





# **Somadores**

Os **Somadores** são circuitos que adicionam dois números que se encontram, habitualmente, em código binário natural.

- A saída é expressa no mesmo código
- Produzem um carry (transporte) ou overflow, se o resultado não couber no número de bits das parcelas:



#### Semi-somador binário

Chama-se **Semi-somador binário**, ou *Half-adder*, ao circuito seguinte que adiciona 2 *bit*s, produzindo um *carry* de saída (ou *output carry*) **C**<sub>out</sub>:

| $A_{i}$ | $B_i$ | S <sub>i</sub> | C <sub>i+1</sub> |
|---------|-------|----------------|------------------|
| 0       | 0     | 0              | 0                |
| 0       | 1     | 1              | 0                |
| 1       | 0     | 1              | 0                |
| 1       | 1     | 0              | 1                |
|         |       | -              |                  |

$$S_{i} = A_{i} \oplus B_{i}$$

$$C_{i+1} = A_{i} \cdot B_{i}$$



Este circuito n\u00e3o suporta um carry de entrada (ou input carry).



# Somador binário completo

Chama-se **Somador binário completo**, ou *Full-Adder*, ao seguinte circuito que adiciona 2 *bit*s, produzindo um *carry* de saída (**C**<sub>out</sub> ou **C**<sub>i+1</sub>) e admitindo um *carry* de entrada (**C**<sub>in</sub> ou **C**<sub>i</sub>):

| $\frac{C_i}{0}$ | $A_i$ | Bi | Si | C <sub>[+1</sub> |
|-----------------|-------|----|----|------------------|
| 0               | 0     | Ō  | 0  | 0                |
| 0               | 0     | 1  | 1  | 0                |
| 0               | 1     | 0  | 1  | 0                |
| 0               | 1     | 1  | 0  | 1                |
| 1               | 0     | 0  | 1  | 0                |
| 1               | 0     | 1  | 0  | 1                |
| 1               | 1     | 0  | 0  | 1                |
| 1               | 1     | 1  | 1  | 1                |

$$S_i = A_i \oplus B_i \oplus C_i$$
  
 $C_{i+1} = A_i \oplus B_i + C_i$ .  $(A_i \oplus B_i)$ 



#### Sistemas Digitais 2023/2024

4 %

Um **somador de N** bits pode então ser implementado da seguinte forma:



#### Sistemas Digitais 2023/2024

A família TTL disponibiliza **Somadores** de 4 *bit*s sob a designação comercial de **7483**:



À semelhança dos **Comparadores**, podem ligar-se **Somadores** em cascata para realizarem somas com um maior nº de *bits*.

Para tal, o *carry* de saída ( $\mathbf{C}_{out}$ ) do somador anterior, liga-se ao *carry* de entrada ( $\mathbf{C}_{in}$ ) do somador seguinte.

